- reportGateCount :
- 2. all\_inputs:
- 3. all\_outputs:
- 4. all clocks:
- 5. sizeof\_collections [all\_outputs]
- 6. dbget top.insts.cell.name -u
- 7. dbget top.insts.cell.name BUF\*
- 8. dbget top.inst.cell.name BUF\*
- dbget [dbget -P2 top.insts.cell.baseclass block].name//Macro Insts
- 10. dbget [dbget -P top.insts.cell.baseclass block].name//Macro cells
- 11. dbget [dbget -P2 top.insts.cell.baseclass block].orient//Macro orientation
- 12. dbget [dbget -P2 top.insts.cell.baseclass block].box//Macro coordinates
- 13. dbget [dbget -P2 top.insts.cell.baseclass core].name//std cells
- 14. dbget [dbget -P2 top.insts.cell.baseclass pad].name//pads
- 15. dbget top.fplan.pBlkge.type //gives blockage type (soft ,hard,partial)
- 16. dbgettop.fplan.pblkge.boxes //blockage coordinateswith out cell view
- 17. dbgettop.fplan.pblkge.box //blockage coordinates with cell view
- 18. createPlaceBlockage -type hard -box {x1,y1,x2,y2}
- 19. setEndcapMode -help
- 20. addEndCap -preCap<filler\_name> -postcap<filler\_name> -prefix name
- 21. addWellTap -cell FILL2 -cellInterval 20 -checkerBoard
- 22. cutRow // is used for cut the row
- 23. dbQury //
- 24. PlaceInstance inst\_name coordinates
- 26. AddInst -cell <cell\_name> -inst<Inst\_name> -loc X1,Y1
- 27. deleteFiller -inst<instname>
- 28. deleteFiller -cell FILL2
- 29. checkNetlist //usd to netlist checks (floating i/p,multidrivenets ,Inst pin check : o/p pins connected to PG net......)
- 30. checkDesign -all
- 31. dbget -regexp [dbget -p2 top.insts.cell.baseClass core].name WELLTAP
- 32. dbget [dbget top.fplan.rows].box //row coordinates
- 33. dbget top.fplan.coreBox
- 34. dbget top.fplan.coresite.size
- 35. dbget top.fplan.pblkgs.type hard
- 36. dbget [dbget -p top.fplan.pBlkgs type hard].boxes
- 37. editDelete -shapes {RING STRIPE} -status {ROUTED FIXED}
- 38. deleteAllPowerPrerouts // it delete all power plane
- 39. dbget top.insts.name END\*
- 40. dbget [dbget -p top.inst.name END\*].box //it gives endCap coordinates]
- 41. setEdit {specify metal and spaceing}

- 42. editAddRoute<X Y>
- 43. editCommitRoute<X Y>
- 44. dbget top.fplan.ioBox //It gives IO boundary coordinates
- 45. dbget top.fplan.ios //it give IO pads
- 46. dbget top.fplan.core2left //it give dist b/w core pads
- 47. specifyCellPad<cell\_name><factor>
- 48. refinePlace
- 49. trialRoute -maxRouteLayer 6
- 50. setPlaceMode -modulePadding<inst\_name>facter
- 51. attachIOBuffer -basename new1 -out BUFX3
- 52. SelectInst New1\*
- 53. Dbget top.insts.cell.name \*FF\* //gives all flip flops
- 54. Dbget [dbget -p2 top.insts.cell.isSequential 1].name //all registers
- 55. All\_registers (or) all\_registers -flops
- 56. Sizeof\_collection [all\_registers -flops] // it give flop count
- 57. QueryDensityInBox x1 y1 x2 y2
- 58. CreateDensityArea x1 y2 x2 y2 50%
- 59. addTieHilo -cell TIELO -prefix TIE
- 60. dbget [dbget -p2 top.insta.instTerms.isTieLo 1].cell.name
- 61. setPlaceMode -congEffort medium
- 62. addNetnewName
- 63. AttachTerm<Inst name><Pin name><net name>
- 64. queryPlaceDensity

## CTS-COMMANDS

- 1. get\_clocks
- 2. get\_property [all\_clocks] period
- **3.** get\_property [all\_clocks] sources
- **4.** get\_property [get\_clocks] clock\_network\_pins
- **5.** ChangeClockStatus -nofixedBuffers -all
- **6.** deleteClockTree -all
- 7. cleanUpSpecifyClockTree
- 8. dbget -regexp [dbgettop.nets].name clk //to get clock net names
- 9. dbget [dbget -p top.nets.isCTSclock 1].name // to get clock net names
- **10.** report clock timing -type skew/latency
- **11.** set\_interactive\_constraint\_modes [all\_constraints] // for Update SDC
- **12.** set\_timing\_derate -delay\_corner dtmf\_corner\_max/min -data 10 -clock 5
- 13. reportTranViolation
- **14.** report\_constraints -AllViolaters //it reports all DRV violations
- **15.** add\_ndr -width {Metal1 0.46 .....}
  - -spacing {Metal1 0.3 . . . . . . . . . . } -name NDR2W2S

- 16. exoprtNdr NDR2W2S -leffilename.lef
- 17. SetCTSMode -routeLeafNonDefaultRule NDR2W2S
- 18. setCTSMode -routeShielding VSS
- 19. setCTSmode -specmultimode true
- 20. createClockTreeSpec -file name.ctstch -bufferlist {CLKINVX2 CLKINVX4 ...... }
- 21. SpecifyClockTree -file name.ctstch
- 22. ClockDesign -specfilename.ctstch
- 23. Dbget [dbget -p1 top.nets.shildNets.Name VSS].name
- 24. Dbget head.rules.name // it gives extra rules from lef
- 25. Dbget [dbget -p top.nets.isCTSclock 1].name
- 26. Dbget top.nets.rule.name 2w2s (it give NDR(2w2s)rules)
- 27. editDelete -type Signal -status {ROUTED FIXED} (it delet fixed nets)
- 28. dbget [dbget -p1 top.insts.cell.terms.type clockTerm].name ....to get sink pins

## Routing:

- getAttribute -net net\_name
- 2. getNetWireLengthnet name
- 3. describeCongestion
- 4. dumpCongestArea -all file name
- 5. dbget [dbget -p head.LibCell.isInverter 1].name
- dbget [dbget -p2 [dbget-p2 top.instcell.isSequential 1]
   .instTerms.cellTerm.typeclockTerm].net.name (it give sequential clk nets)
- 7. dbget [dbquery -area {\_ \_ \_ \_}].box
- 8. get metric (give all detales)
- 9. set\_analysismode -analysisTypeonChipVariation
- 10. get\_property [get\_property [get\_clocks] clock\_network\_pins] actual\_latency\_late\_fall\_max
- 11. all\_fanout -from pin\_name \_endpoint\_only
- 12. report\_clock\_timing -type skew
- 13. report\_clocks –unsertainty\_table
- 14. reOut -speffile\_name.spef -reg\_cornercorner\_name
- 15. creatInstGroupgroup\_name -guid box (give co-ordinats)
- 16. setDoAssign -buffer buf name on
- 17. ecoChangeCell -inst name -upsize
- 18. report\_timing —net -from beginingpoint -to endpoint -path\_typefull\_clock —through instname
- 19. group path
- 20. setEcoMode -updatetiming false/true
- 21. setCheckMode -Netlist true -true //default getCheckMode
- 22. CreateInstGroup group\_Name -fence x1 y1 x2 y2

- 23. addInstToInstGroup group\_name instName
- 24. SetInstGroupPhyttier group\_Name
- 25. EcoAddRepeater -cell DLY2X1 -net Net\_Name -relativeDisttosink 0.1 // (It place Near to sink)
- 26. SpecifyNetWeight<net\_name><net\_weight value>
- 27. editSelect -layer {metal1 metal2}

28.

## SCAN CHAIN

ScanTrace //It reports start & end points & elements

ScanReorder

displayScanChain

Set\_analysis\_view -setup view\_name -hold view\_Name -update\_timing

All\_constraint\_modes //get\_constraint\_mode

All\_constrint\_modes -active

## TIMING

Report\_timing [all\_registers] -to [all\_registers]

Group\_path -name r2r -from [all\_reg] to [all\_reg]

Report\_timing -path\_group r2r

Report\_timing -path\_group r2r -max\_paths 100

Report\_timing -path\_group r2r -max\_paths 100 -nworst 10 //it gives no of worst paths

Report\_timing -path\_group r2r -max\_paths 10 -nWorst 10 -through <inst\_name>

Set\_propagated\_clock

Report\_timing -path\_typefull\_clock

Report\_timing -path\_type summary

Report\_timing -machine\_readable

Report -from [all\_registers] -to [all\_registers] -machine\_readable> a

```
Report_timing -early //for hold
Report_timing -collection //
Set x [report_timing -from [all_reg] -to [all_reg] -collection]
Get_property $x path
Get_property $x slack /startpoint/endpoint/arrival/setup
List_property $x
Get_property [all_clocks] source
Get_property [all_clocks] period
Get_property [all_clocks] waveform
TimeDesign -reportsonly -help //gives all reports
First DO:
      Report_timing -machine_readable>file_name
      Load_timing_debug_report filename
DRV Checks:
      Analyze_paths_by_drv
                                -generate_tran_file<file_name>
```

setEndCapMode -leftTopCorner FILL4 -leftTopEdge FILL4 -leftBottomEdge FILL4 - leftBottomCorner FILL4 -prefix end\_left

-generate\_cap\_file<file\_name>

-generate\_fanout\_file<file\_name>

- setEndCapMode -rightEdge FILL2 -leftEdge FILL2 -topEdge {FILL2 FILL32} -bottomEdge {FILL2 FILL32}
- addEndCap